#include <iostream>

using namespace std;
const int N=1e5+10;
int a[N];
int tr[N];
int ret[N];
int n;
int lowbit(int x)
{
	return x&(-x);
}
void add(int x,int c)
{
	for(int i=x;i<=n;i+=lowbit(i))
	{
		tr[i]+=c;
	}
}

int sum(int x)
{
	int ret=0;
	for(int i=x;i>0;i-=lowbit(i))
	{
		ret+=tr[i];
	}
	return ret;
}
int main()
{
	cin>>n;
	for(int i=2;i<=n;i++)
	{
		scanf("%d",&a[i]);
	}
	for(int i=1;i<=n;i++)
	{
		add(i,1);
	}
	for(int i=n;i>=1;i--)
	{
		int left=1,right=n;
		while(left<right)
		{
			int mid=(left+right)>>1;
			if(sum(mid)>=a[i]+1)
			{
				right=mid;
			}
			else{
				left=mid+1;
			}
		}
		add(right,-1);
		ret[i]=right;
	}
	for(int i=1;i<=n;i++)
		cout<<ret[i]<<endl;
	return 0;
}
